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DETAILED ACTION 



1. 



This office action is in response to remark filed on Feb. 10, 2008. 



2. 



Claims 1-3, 5, 7, 9-13, 15-18, 20, and 24-32 are pending. 



Claim Rejections - 35 USC §101 



3. 35 U.S.C. 101 reads as follows: 

Whoever invents or discovers any new and useful process, machine, manufacture, or composition of matter, or an> new and 
useful improvement thereof, may obtain a patent therefor, subject to the conditions and requirements of this title. 

Claims 13-15 are rejected under 35 USC 101 because the body of the claims recites various 
modules which are interpreted to be software per se. 



4. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 

5. Claims 1-3, 5, 7, 12, 13, 15 and 25- 30 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Bade et al. (US Pub. No.20020059054 Al, hereinafter "Bade"), in view of 
Mulchandanii et al. (US Patent No. 5,701,488, hereinafter "Mulchandanii"). 

Per claim 1 

Bade discloses 

■ A method of displaying embedded firmware program information ([0021] "An 
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integrated design environment (IDE) is disclosed for simulating embedded systems") 
Comprising: 

■ displaying a first screen to interact with a user for high level function selections ([0101] 
"As shown in FIG.21the IDE preferably has a menu-driven graphical user interface that 
preferably includes a design window for creating a design with toolbars for accessing 
functions using a computer mouse or similar interface. The IDE preferably includes a 
peripheral design editor and simulator that is adapted to permit hardware IP components 
and processes to be created and linked with other IP components. "). 

■ displaying a second screen to show hardware resources for a programmable circuit 
([0099] "As shown in FIGS. 28, 29, and 37, the use of an instruction set accurate 
simulator to model a processor core permits the processor simulator to exchange 
memory transactions with the hardware partition and to receive interrupts from the 
hardware partition using APIs linking the hardware partition and the instruction set 
accurate simulator. "). 

■ displaying a third screen to show source code for a plurality of source code programs to 
control the programmable circuit ([0173] "The IDE preferably features a high-quality 
C+ + code generator, hiding all the details of generating simulation code... ") 

■ displaying a fourth screen to render symbolic information associated with the displayed 
source code ([0104] "FIG. 36B shows an example of a software debugger interface 
window 3685 superimposed over a design window 3620 of a virtual embedded system. " 
& In Fig. 36B shows the design window 3620 associated with source code that is 
debugging in debugger window 3620). 
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The symbolic information comprising: 

■ listings including named registers, data labels for word, byte and short entities and name 
of data structures ([0163] 'As shown in FIG. 26, a Test Bench Builder Toolbar is 
preferably included to represent the test bench controls, such as a LED, LCD, memory 
viewer, ASCII terminal window, resource meter, or signal button, and the test bench 
builder, allows a user to quickly add these controls to a test bench." ; the memory viewer 
may view data words, short words and byte values; and register viewer may list 
information associated with registers). 

■ address locations for the code labels and the data labels ([0105] "FIG. 38 is a screen shot 
of an exemplary processor symbol 3805 and two peripherals 3830 and 3840. FIGS. 39- 
40 are exemplary screen shots showing a Configuration Wizard and configuration data 
for coupling read/write memory transactions and interrupt signals between the FSM 
representation of the hardware peripherals and the ISA processor... "). 

But Bade does not disclose 

■ code labels, data labels referring to data structures comprising fields, data register names, 
and index register names; addresses and values of the word containing a start of the field. 

However Mulchandani discloses MCUdebug which supports 3 different modes of viewing bus 
state analyzer data 

■ code labels, data labels referring to data structures comprising fields, data register names, 
and index register names; and names of the data structures (col.7 lines 41-47 "Table T-l 
is an example of an "Instruction Mode" Bus State Analyzer display. The columns in Table 
T-l are "FrU"' (Frame Number), "A&. " (Instruction Address), "Data (normally opcode), 



Application/Control Number: 10/748,427 Page 5 

Art Unit: 2191 

"Label", "Codede" and "Bus Cycle". MCUdebug supports a wide range of commands 
which allow a user to perform custom setup of the analyzer" & col. 13 lines 23-30 
"MCUdebug provides a rich set of functions which can allow a user to view analyzer 
data in variety of ways. The Bus State Analyzer window displayed in Table 1 is an 
example of the "Instructions Only" view mode of the bus state analyzer data. In the right 
section of the window (under the label "Bus Cycle") the data displayed shows the actual 
bus cycle that occurred on the execution of that particular instruction. "& col. 12 lines 20- 
27 & see Table T-l). 

■ Bade discloses data structures and the fields of the data structure are individually 
expandable (Refer to Fig. 3 1 & [0169] "As illustrated in FIG. 31, A Library Browser is 
preferably included, as part of the Design Browser Window. Using this browser, a 
designer can explore different libraries that are currently opened in the design, and 
inspect which Symbols, Processes and Blocks they contain. By left-clicking on a Symbol, 
Block or Process, the construct can be opened directly and edited. ". In Fig.3 1 , in the 
ordinary skill of arts, user may click a on the '+' button to expand hierarch to show its 
sub-structure and click a '-' button to collapse an expanded hierarch.") Further, 
Mulchandani discloses MCUdebug which supports 3 different modes of viewing bus 
state analyzer data comprising address and values of the word containing a start of the 
field (see Table T-l col.7 lines 40-47). 

■ Therefore, it would have been obvious to a person of ordinary skill in the art at the time 
the invention was made to combine teaching of Bade where data structure and the fields 
of data structure (refer as library) are individually expandable with the teachings of 
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Mulchandani to include code labels, data labels referring to data structures, data register 
names, and index register names and addresses and values of the word containing a start 
of the field in order to provide some information close to console from debugger and 
allow a user to observe the state of the application at any point (col.4 lines 32-40). 

Per claim 2 

the rejection of claim 1 is incorporated and Bade further discloses 

■ displaying source code associated with a symbol in the fourth screen selected by user 
([0101] "Referring to FIG. 15, in a preferred embodiment the graphical object symbols 
may be selected from a menu 1520, a textual portion of the object input by the user, and 
the graphical object connected to other graphical objects using connectors 1505. "). 

Per claim 3 

the rejection of claim 2 is incorporated and Bade further discloses 

■ displaying a view source button in the fourth screen configured to be activated by a 
computer mouse to view source code associated with symbol (As shown in FIG. 15 or 
toolbar shown in FIG.25, the button C is for generate C+ + code when user click it by 
mouse). 

Per claim 5 

the rejection of claim 1 is incorporated and Bade further discloses 

■ displaying the symbolic information in the fourth screen without typing by the user 
([0101] "Referring to FIG. 15, in a preferred embodiment the graphical object symbols 
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may be selected from a menu 1520, a textual portion of the object input by the user, and 
the graphical object connected to other graphical objects using connectors 1505. "). 

Per claim 7 

the rejection of claim 1 is incorporated and Bade further discloses 

■ displaying a device enabling expansion of the displayed symbolic information ([0129] 
"FIG. 16 shows a Block construct containing a single Process construct, two Block 
constructs and a Declaration construct. " & [0131] "In the example, the interrupt 
controller waits for an interrupt signal, as sent by one of the two peripheral devices. The 
Symbol for a Signal-In construct is a rectangle with an arrow pointing inward as either 
its left or right side. "). 

Per claim 12 

the rejection of claim 1 is incorporated and Bade further discloses 

■ the programmable circuit includes a processor ([0021 ] "The IDE includes 

a graphical user interface and a design language for forming finite state machine models 
of hardware components that are coupled to processor simulators, preferably instruction 
set accurate simulators of processor cores. "). 

Per claim 13 

■ Same reasons as rejected to claim 1 . 



Per claim 15 
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the rejection of claim 13 is incorporated and Bade further discloses 

■ the device includes a processor ([0021] "The IDE includes a graphical user interface and 
a design language for forming finite state machine models of hardware components that 
are coupled to processor simulators, preferably instruction set accurate simulators of 
processor cores. "). 

Per claim 25 

the rejection of claim 1 is incorporated 
Bade further discloses 

■ the data structures and the fields of the data structures are individually expandable 
comprises the data structures and the fields of the data structures being configured to be 
expandable by a user using a user interface (Refer to Fig. 30 & [0164] ". . .allowing in a 
single click to quickly browse and navigate a design's hierarchy or signal connectivity." 
In Fig. 30, in the ordinary skill of arts, user may click a on the '+' button to expand 
hierarch to show its sub-structure and click a '-' button to collapse an expanded 
hierarch.). 

Per claim 26 

the rejection of claim 25 is incorporated 
Bade further discloses 

■ the data structures and the fields of the data structures are configured to be individually 
collapsible after being expanded by a user using a user interface (Refer to Fig. 30 & 
[0164] ". . .allowing in a single click to quickly browse and navigate a design's hierarchy 
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or signal connectivity." In Fig. 30, in the ordinary skill of arts, user may click a on the '+' 
button to expand hierarch to show its sub-structure and click a '-' button to collapse an 
expanded hierarch.). 

Per claim 27 

the rejection of claim 25 is incorporated 
Bade further discloses 

■ the user interface is a mouse interface ([0 1 0 1 ] "As shown in FIG. 2 1 , the IDE preferably 
has a menu-driven graphical user interface that preferably includes a design window for 
creating a design with toolbars for accessing functions using a computer mouse or similar 
interface. "). 

Per claim 28 

the rejection of claim 13 is incorporated 
Bade further discloses 

■ the data structures and the fields of the data structures are individually expandable 
comprises the data structures and the fields of the data structures being configured to be 
expandable by a user using a user interface (Refer to Fig. 30 & [0164] ". . .allowing in a 
single click to quickly browse and navigate a design's hierarchy or signal connectivity." 
In Fig. 30, in the ordinary skill of arts, user may click a on the '+' button to expand 
hierarch to show its sub-structure and click a '-' button to collapse an expanded 
hierarch.). 
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Per claim 29 

the rejection of claim 28 is incorporated 
Bade further discloses 

■ the data structures and the fields of the data structures are configured to be individually 
collapsible after being expanded by a user using a user interface (Refer to Fig. 30 & 
[0164] ". . .allowing in a single click to quickly browse and navigate a design's hierarchy 
or signal connectivity." In Fig. 30, in the ordinary skill of arts, user may click a on the '+' 
button to expand hierarch to show its sub-structure and click a '-' button to collapse an 
expanded hierarch.). 

Per claim 30 

the rejection of claim 28 is incorporated 
Bade further discloses 

■ the user interface is a mouse interface ([0101] "As shown in FIG. 21, the IDE preferably 
has a menu-driven graphical user interface that preferably includes a design window for 
creating a design with toolbars for accessing functions using a computer mouse or similar 
interface. "). 

6. Claim 9 is rejected under 35 U.S.C. 103(a) as being unpatentable over Bade, in view of 
Mulchandani and further view of van Hoff et al. (U.S. Patent No. 5,778,231 hereinafter "Hoff '). 
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Per claim 9 

the rejection of claim 1 is incorporated 
Both Bade and Mulchandani do not disclose 

■ parsing the source code to create the listings in the fourth screen. 
But Hoff discloses 

■ parsing the source code to create the listing in the fourth screen (col.2 lines 12-17 "The 
inventive compilation method for compiling program source code on a computer to 
generate compiled code includes identifying symbol references in the source code 
sequentially as the symbolic references occur in the source code, and parsing the code 
during the compilation to identify each symbol that references another program. "). 

■ Therefore, it would have been obvious to a person of ordinary skill in the art at the time 
the invention was made to combine teachings of Bade and Mulchandani and further 
include parsing the source code to create the listings in the fourth screen by teachings of 
Hoff in order to identify externally defined symbols so that the compiler can determine 
whether the symbols is reference to a remotely located file or to a locally stored file. 
(Hoff, col.5 lines 42-49). 

7. Claim 10 is rejected under 35 U.S.C. 103(a) as being unpatentable over Bade, in view of 
Mulchandani, Hoff and further view of Hall et al. (US Patent No.4, 720,778 hereinafter "Hall"). 



Per claim 10 

the rejection of claim 9 is incorporated 
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Bade, Mulchandani and Hoff do not disclose 

■ outputting symbolic information for a data structure recursively until resultant fields are 
no longer structures. 

However Hall discloses 

■ outputting symbolic information for a data structure recursively until resultant fields are 
no longer structures (col. 13 lines 36-38 "Values of important variables can be seen at 
each level of a recursive procedure; this is especially useful if a procedure is stuck in 
infinite recursion"). 

■ Therefore, it would have been obvious to a person of ordinary skill in the art at the time 
the invention was made to combine teachings of Bade, Mulchandani and Hoff and further 
include outputting symbolic information for a data structure recursively until resultant 
fields are no longer structures by the teachings of Hall in order to trace the values of data 
at the entry and exit points of procedure. (Hall, col. 13 lines 23-24). 

8. Claim 1 1 is rejected under 35 U.S.C. 103(a) as being unpatentable over Bade, in view of 
Mulchandani, and further view of Smith et al. (U.S. Patent No. 6,3 1 1 ,324 B 1 hereinafter 
"Smith"). 
Per claim 1 1 

the rejection of claim 1 is incorporated 
Both Mulchandani and Bade do not disclose 

■ displaying the symbolic information for particular regions of the source code 
But Smith discloses 
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■ displaying the symbolic information for particular regions of the source code (col. 4 
lines 36-39 "a tuning program proceeds to analyze application code modules to identify 
critical regions called hotspots, and displays a graphical view of every hotspot in a 
module"). 

■ Therefore, it would have been obvious to a person of ordinary skill in the art at the time 
the invention was made to combine teachings of Bade and Mulchandani and further 
include displaying the symbolic information for particular regions of the source code by 
the teachings of Smith in order to help the user to analyze the region. Once the region has 
been identified and analyzed, the program advises the user on how to rewrite the program 
code to improve the performance of the overall application. (Smith, col.3 lines 4-9). 



9. Claims 16-18, 20 and 3 1- 32 are rejected under 35 U.S.C. 103(a) as being unpatentable 
over Bade, in view of Mulchandani, Hoff and further view of Hall. 
Per claim 16 

■ Same reasons as rejected to claim 1 . 



Per claim 17 

the rejection of claim 16 is incorporated and Bade further discloses 

■ displaying source code selected by user ([0101] "Referring to FIG. 15, in a preferred 
embodiment the graphical object symbols may be selected from a menu 1520, a textual 
portion of the object input by the user, and the graphical object connected to other 
graphical objects using connectors 1505. "). 
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Per claim 18 

the rejection of claim 16 is incorporated and Bade further discloses 

■ displaying the source code in the fourth screen selected by the user by clicking on a view 
source button (As shown in FIG. 15 or toolbar shown in FIG. 2 5, the button C is for 
generate C+ + code when user click it by mouse). 

Per claim 20 

the rejection of claim 16 is incorporated and Bade further discloses 

■ displaying the symbolic information in the fourth screen without typing by the user 
([0101] "Referring to FIG. 15, in a preferred embodiment the graphical object symbols 
may be selected from a menu 1520, a textual portion of the object input by the user, and 
the graphical object connected to other graphical objects using connectors 1505. "). 

Per claim 3 1 

the rejection of claim 16 is incorporated 
Bade further discloses 

■ the data structures and the fields of the data structures are individually expandable 
comprises the data structures and the fields of the data structures being configured to be 
expandable by a user using a user interface (Refer to Fig. 30 & [0164] ". . .allowing in a 
single click to quickly browse and navigate a design's hierarchy or signal connectivity." 
In Fig. 30, in the ordinary skill of arts, user may click a on the '+' button to expand 
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hierarch to show its sub-structure and click a '-' button to collapse an expanded 
hierarch.). 

Per claim 32 

the rejection of claim 31 is incorporated 
Bade further discloses 

■ the data structures and the fields of the data structures are configured to be individually 
collapsible after being expanded by a user using a user interface (Refer to Fig. 30 & 
[0164] ". . .allowing in a single click to quickly browse and navigate a design 's hierarchy 
or signal connectivity.'" In Fig.30, in the ordinary skill of arts, user may click a on the '+' 
button to expand hierarch to show its sub-structure and click a '-' button to collapse an 
expanded hierarch.). 

10. Claim 24 is rejected under 35 U.S.C. 103(a) as being unpatentable over Bade et al, in 
view of Mulchandani, Hoff, and Hall and further view of Smith. 

Per claim 24 

the rejection of claim 16 is incorporated 

Bade, Mulchandani, Hoff and Hall do not disclose 

■ displaying the symbolic information for particular regions of the source code in the fourth 
screen 

But Smith discloses 
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■ displaying the symbolic information for particular regions of the source code in the fourth 
screen (col.4 lines 36-39 "a tuning program proceeds to analyze application code 
modules to identify critical regions called hotspots, and displays a graphical view of 
every hotspot in a module "). 

■ Therefore, it would have been obvious to a person of ordinary skill in the art at the time 
the invention was made to combine teachings of Bade, Mulchandani, Hoff and Hall and 
further include displaying the symbolic information for particular regions of the source 
code in the fourth screen by the teachings of Smith in order to help the user to analyze the 
region. Once the region has been identified and analyzed, the program advises the user on 
how to rewrite the program code to improve the performance of the overall application. 
(Smith, col.3 lines 4-9). 



Response to Arguments 

Applicant's arguments filed on Feb. 10, 2009 have been fully considered but they are not 
persuasive. 

■ In the remarks, Applicant argues that: 
(a) In regard to independent claims 1,13 and 16, prior art fails to data structures and the field 
of the data structure are individually expandable to show respective addresses and values of the 
word containing a start of the field. 



Application/Control Number: 10/748,427 Page 17 

Art Unit: 2191 

Examiner's response: 

Examiner disagrees. 

(a) Prior art Bade discloses in Fig. 3 1 shows the design browser associated with Bade 
discloses data structures and the fields of the data structure are individually expandable (Refer to 
Fig. 31 & [0169] "As illustrated in FIG. 31, A Library Browser is preferably included, as part of 
the Design Browser Window. Using this browser, a designer can explore different libraries that 
are currently opened in the design, and inspect which Symbols, Processes and Blocks they 
contain. By left-clicking on a Symbol, Block or Process, the construct can be opened directly 
and edited. ". In Fig. 3 1, in the ordinary skill of arts, user may click a on the '+' button to expand 
hierarch to show its sub-structure and click a '-' button to collapse an expanded hierarch.") 
Further, Mulchandani discloses MCUdebug which supports 3 different modes of viewing bus 
state analyzer data comprising address and values of the word containing a start of the field (see 
Table T-l col. 7 lines 40-47 ""State" --Address and data information along with POD information 
is displayed. Table T-l is an example of an "Instruction Mode" Bus State Analyzer display. The 
columns in Table T-l are "Fr#" (Frame Number), "Adr. " (Instruction Address), "Data (normally 
opcode), "Label", "Code", and "Bus Cycle". MCUdebug supports a wide range of commands 
which allow a user to perform custom setup of the analyzer ") 

Therefore, it would have been obvious to a person of ordinary skill in the art at the time the 
invention was made to combine teaching of Bade where data structure and the fields of data 
structure (refer as library) are individually expandable with the teachings of Mulchandani to 
include addresses and values of the word containing a start of the field to discloses or suggest the 
foregoing feature in claim 1 . 



Application/Control Number: 10/748,427 
Art Unit: 2191 



Page 18 



Conclusion 

1 1 . THIS ACTION IS MADE FINAL. Applicant is reminded of the extension of time 
policy as set forth in 37 CFR 1.136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within TWO 
MONTHS of the mailing date of this final action and the advisory action is not mailed until after 
the end of the THREE-MONTH shortened statutory period, then the shortened statutory period 
will expire on the date the advisory action is mailed, and any extension fee pursuant to 37 
CFR 1.136(a) will be calculated from the mailing date of the advisory action. In no event, 
however, will the statutory period for reply expire later than SIX MONTHS from the mailing 
date of this final action. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to JUNCHUN WU whose telephone number is (571)270-1250. The 
examiner can normally be reached on 8:00-17:00 M-F. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Wei Zhen can be reached on 571-272-3708. The fax phone number for the 
organization where this application or proceeding is assigned is 571-273-8300. 
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Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). If you would 
like assistance from a USPTO Customer Service Representative or access to the automated 
information system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 

JW 

/Wei Y Zhen/ 

Supervisory Patent Examiner, Art Unit 2191 



